home *** CD-ROM | disk | FTP | other *** search
- ;;; -*- Package: C; Log: C.Log -*-
- ;;;
- ;;; **********************************************************************
- ;;; This code was written as part of the CMU Common Lisp project at
- ;;; Carnegie Mellon University, and has been placed in the public domain.
- ;;; If you want to use this code or any part of CMU Common Lisp, please contact
- ;;; Scott Fahlman or slisp-group@cs.cmu.edu.
- ;;;
- (ext:file-comment
- "$Header: pred.lisp,v 1.6 91/02/20 15:15:00 ram Exp $")
- ;;;
- ;;; **********************************************************************
- ;;;
- ;;; $Header: pred.lisp,v 1.6 91/02/20 15:15:00 ram Exp $
- ;;;
- ;;; This file contains the VM definition of predicate VOPs for the MIPS.
- ;;;
- ;;; Written by Rob MacLachlan
- ;;;
- ;;; Converted by William Lott.
- ;;;
-
- (in-package "MIPS")
-
-
- ;;;; The Branch VOP.
-
- ;;; The unconditional branch, emitted when we can't drop through to the desired
- ;;; destination. Dest is the continuation we transfer control to.
- ;;;
- (define-vop (branch)
- (:info dest)
- (:generator 5
- (inst b dest)
- (inst nop)))
-
-
- ;;;; Conditional VOPs:
-
- ;if-true (???), if-eql, ...
-
- (define-vop (if-eq)
- (:args (x :scs (any-reg descriptor-reg zero null))
- (y :scs (any-reg descriptor-reg zero null)))
- (:conditional)
- (:info target not-p)
- (:policy :fast-safe)
- (:translate eq)
- (:generator 3
- (let ((x-prime (sc-case x
- ((any-reg descriptor-reg) x)
- (zero zero-tn)
- (null null-tn)))
- (y-prime (sc-case y
- ((any-reg descriptor-reg) y)
- (zero zero-tn)
- (null null-tn))))
- (if not-p
- (inst bne x-prime y-prime target)
- (inst beq x-prime y-prime target)))
- (inst nop)))
-
-
-